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BANCO DE DADOS E JDEC 


À maioria dos sistemas precisa armazenar as informações com as quais eles 
trabalham, seja para permitir consultas futuras, geração de relatórios ou possíveis 
alterações nos dados. Para que esses dados sejam mantidos para sempre, esses sistemas 
geralmente guardam essas Informações em um banco de dados, que as mantém de forma 
organizada e pronta para consultas. 

Para evitar que cada banco tenha a sua própria API e conjunto de classes e métodos, o 
Java possui um único conjunto de interfaces muito bem definidas que devem ser 
implementadas que ficam dentro do pacote java. sql e nos referiremos a ela como JDBC. 


| q 


Oracle SOL Server MySQL 


Para abrir uma conexão com um banco de dados, precisamos utilizar sempre um 
driver. À classe DriverManager é a responsável por se comunicar com todos os drivers que 
você deixou disponível. Para isso, invocamos o método estático getConnection com uma 
String que indica a qual banco desejamos nos conectar. A String de conexão JDBC utilizada 
para acessar o MySQL tem sempre a seguinte forma: 


Jdbc:mysql:/1p/nome do banco 


Devemos substituir 1p pelo IP da máquina do servidor e nome do banco pelo nome do 
banco de dados a ser utilizado. Precisamos adicionar o driver do banco de dados ao 
classpath, o arquivo jar contendo a implementação JDBC do banco à variável de ambiente 
CLASSPATH. Esse procedimento é o mesmo para MySQL, SQLServer, Oracle e qualquer 
outro banco de dados. 


19.1. EXERCÍCIOS: Fábrica de Conexões 





1) Inicie o WampServer através do menu Iniciar. 


2) Clique no ícone do Wamp e acione MySQL > MySQL console. 
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3) Crie a base de dados jdbc: 
create database jJdbc; 

4) Prepare-se para usar o banco de dados criado: 
use jJdbc; 

5) Crie a seguinte tabela: 


create table produto ( 

1d INT PRIMARY KEY AUTO INCREMENT, 
nome VARCHAR (50), 

descricao VARCHAR (255), 

preco double); 


6) Abra o Eclipse no Desktop. 

1) Feche a tela de Welcome caso ela apareça. 

8) Vá em File 9 New 9 Project. 

9) Selecione Java Project e clique em Next; 

10) Coloque o nome do projeto como ds1-jdbc e clique em Finish; 


11) Aceite a mudança de perspectiva. 


Li Open Associated Perspective? 


2 This kind of project is associated with the Java perspective. 
“o 


This perspective 15 designed to support Java development. k offers a Package 
Explorer, a Type Hierarchy, and Java-specific navigation actions. 


Do you want to open this perspective now? 


[ ]Remember my deciston 





12)Copie o driver do MySQL para o seu projeto. 
a. Acesse o moodle e localize a pasta JDBC. 
b. Copie o driver mysql-connector-java-5.1.6-bin; 
c. Retorne ao Eclipse, selecione seu projeto e cole o arquivo no seu projeto. 


13) Crie os pacotes abaixo na pasta src: 
br.com.etec.jydbc.dao 


br.com.etec. jyjdbc.modelo 
br.com.etec.jydbc.teste 
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14)Crie a classe que fábrica conexões no pacote br. com.etec. jdbc. dao com o nome de 
ConnectionFactory. 


8; New Java Class ——e 


Java Class 7 
Create a new Java class, 
Source folder: ds] -pdbc/sre | Browse, | 


Package: br.com.etecjdbe.dao | Browse... | 
[| Enclosing type: Browse. 
Name: ConnectionFacton, 

IModifiers: o) public + default private protected 


15)No código, crie o método getConnection que retorna uma nova conexão. (Quando 


perguntado, importe as classes do pacote java.sql (cuidado para não importar de 
com.mysql)). 


poblic class ConnectionFactorvy | 


poblic Connection getConnection ()tf 





O método getConnection() é uma fábrica de conexões, isto é, ele cria novas 
conexões. Basta invocar o método e receberemos uma conexão pronta para uso, não 
importando de onde elas vieram e eventuais detalhes de criação. 


a. Ágora, posicione o mouse sobre erro e escolha a opção: Surround with try/ 
catch. O tratamento da exception será tratada nesse momento. 


poblic class ConnectionFfactory | 


poblic Connection getConnection () f 








“43 Unhandled exception type 5QLException 





2 quick fixes available: 
J0 Add throws declaration 
Jo Surround with try/catch 





ns 


b. Altere para uma exception ser lançada: 


ja E = = n“nonaa 173 


ES PN Material do Curso Técnico em Informática 
HORÁCIO AUGUSTO DA SILVEIRA Desenvolvimento de Software I 





public Connection getConnection()tf 
try 1 
return DriverManager. getConnection("jdbce:mysgl://localhost/jdbce"”, "root", Pr: 
* catch (SQLException e 





throw new RuntimeException(e); 


2) Crie uma classe chamada TestaConexao no pacote br.com.etec. jdbc.teste com 
um método main dentro da classe. Use o atalho do Eclipse para ajudar. 





Name: (| TestaConexao 


IModifiers: (+) public (O default private protected 





[abstract [ [final 


Superclass: Javadang.Object | Browse. | 


o E e 


Which method stubs would you like to create? 
«El 
[| Constructors 
Inherited abstract methods 









public static void main(String[] aro) 


rom superclass 


3) Dentro do main, fabrique uma conexão usando a ConnectionFactory que criamos. 
Vamos apenas testar a abertura da conexão e depois fechá-la com o método close: 























10 panblic static void main (String[] args) throws 5SQLException (f 

11 

14 Connection connection = new ConnectionFactory (|) .getConnection()s 
13 System. out.println ("Conexão aberta!”); 

14 connection.close ()r 

15 

16 k 

4) Rode a sua classe TestaConexao pelo Eclipse. 


5) A aplicação não funciona, pois o driver não foi encontrado. 


Do wu nfufai! ER 


ESCOLA TÉCNICA ESTADUAL PROFESSOR Material do Curso Técnico em Informática 
HORÁCIO AUGUSTO DA SILVEIRA Desenvolvimento de Software I 





Cl Console &3 X Eu Ssitata nal mui 
<«terminated> TestaConexao [Java Application] ChArquivos de programas'avaijrel.5Mbin'javaw.exe (28/07/2011 16:57:22) 
Exception in thread "main" java. lang. Runtimetxception: java.sgl. 5SQLException 







at br.com.etec. jdbc.modelo. ConnectionFfactory. getConnection (ConnectionFacto 
at br.com.etec.jdbc. teste. Testalonexao.main (TestaConexao.java:11) 
Caused by: java.sql.5QLException: No suitable driver found for jdbc:mysql://localhost/ijdbe 
at java. sql. DriverManager. getConnection (Unknown Source) 
at Jjava.sql. bDriverManager.getConnection (Unknown Source) 
at br.com.etec. jdbc.modelo. ConnectionFfactorv. getConnection (ConnectionFactory.java:ll) 
« 1 more 


[4 
[e 


6) É necessário colocar o JAR do driver MySQL no classpath do projeto. 
a. Selecione o seu driver do MySQL; 
b. Clique com o botão direito do mouse e escolha Build Path 2 Add to Build Path; 


1) Rode novamente sua aplicação TestaConexao. 


19.2. JAVABEANS 





Javabeans são classes que possuem o construtor sem argumentos e métodos de acesso 
do tipo get e set como, por exemplo, as classes de modelo de nossos projetos. À especificação 
JavaBeans é muito grande e mais Informações sobre essa vasta área que é a base dos 
componentes escritos em Java pode ser encontrada em: 


http:/hava.sun.com/products/javabeans 


19.3. EXERCÍCIOS: Javabeans 





1) Crie a classe Produto no pacote br.com.etec. jdbc.modelo. Ela será nosso 
JavaBean para representar a entidade do banco. Deverá ter id, nome, descrição e preço. 


pablic class Produto f 
private int id; 
private String nome; 
private String descricao; 
private double preco; 


Maça, 


impo 


2) Gere os getters e setters para cada atributo: Aperte Ctrl + 3, digite ggas que é a 
abreviação de Generate getters and setters e selecione todos os getters e setters. 


19.4. DATA ACCESS OBJECT 
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A idéia do Data Access Object é colocar o código de acesso ao banco de dados em uma 
classe responsável pelo acesso aos dados. Assim o código de acesso ao banco de dados fica 
em um só lugar, tornando mais fácil a manutenção. 


19.5. INTERFACES DO JDBC 





Às principais classes e interfaces do pacote java.sql são: 







ResultSet Statement  =— Connection == Driver Manager =—— Driver 


CallableStatement | 





Específico para O 
" banco de dados 


= Java.sgl.DriverManager 
= Gerencia múltiplas implementações da interface Driver 
= O driver é carregado usando: 
— Class.forName ( “nome-driver”) 


= java.sgl. Statement 
= Interface para criação de objetos que representam as Instruções para o banco 
de dados (Statements) 
= Controle de transação 
= [Liberação de recursos 


= Java.sgl. Statement 
= Interface para o envio de comandos SQL ao banco de dados 
= Statements são fabricados por meio da chamada a métodos da interface 
Connection 


= java.sgl.ResultSet 
= Interface que oferece métodos para recuperar resultados de comandos SQL 
executados sobre o banco de dados 
« Navegação nos resultados 


= Jjava.sgl.PreparedStatement 
= (Contém os métodos da classe Statement e outros recursos como a 


possibilidade de passagem de parâmetros na construção de strings SQL 


= java.sgl.CallableStatement 
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= Permite executar procedimentos e funções armazenados no banco como, por 
exemplo, chamadas a stored procedures 


19.6. EXERCÍCIOS: Inserindo dados 





1) Crie a classe ProdutoDAO no pacote br. com.etec. jdbc. dao. Crie um atributo do tipo 
Connection chamado connection. 


paoblic class ProdutoDÃO ( 
*f atributo da classe 
ça aaa aa na aa ma am a a, mama, taça aa na aa um ua a, 


private Connection connection; 


2) Para a conexão, vamos criá-la no construtor. Aperte Ctrl + 3, digite gcfs que é a 
abreviação de Generate Constructor from Superclass e marque a opção Omit call 
to default constructor super (). Codifique o construtor conforme o exemplo a seguir: 


pablic class ProdutoDÃO 
'f atributo da classe 
A O O PA SO 


private Connection connection; 


ff construtor da classe 
mo a pp pp a rm, pt ap a, 


pablic ProdutoDÃO () f 
this.connection = new ConnectionFactorvy().getConnection();: 


3) Faça o import automaticamente (CTRL+Shift+o). Lembre-se de importar as classes de 
SQL do pacote java. sql. 


4) O próximo passo é completar o método de adição de produtos. Ele recebe um objeto do 
tipo Produto como argumento e encapsula totalmente o trabalho com o banco de dados. 


poblic void insere (Produto produto) | 

try | 

PreparedStatement stmt = connection 
-. prepareStatement ("insert into produto values (?,?,%,?)1");s 

stmt. set5String (1, naoll)s 
stmt. setõString(*, produto. getNome ())r 
stmt. setôString (3, produto. getDescricao ()); 
stmt. setDouble (4, produto.getPreco ()); 
stmt.execute (); 
stmt.close ();s 

:+ catch (SQLException e) ft 
throw new RuntimeException (e); 
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Perceba que colocamos os pontos de interrogação porque não sabemos o que desejamos 
Inserir. Estamos Interessados em executar aquele código mas não sabemos ainda quais são 
os parâmetros que iremos utilizar no código SQL que será executado, chamado de 
statement. 

Logo em seguida, chamamos o método setString do PreparedStatement para 
preencher os valores que são do tipo String, passando a posição (começando em 1) da 
interrogação no SQL e o valor que deve ser colocado. 

O preço é do tipo double, então chamamos o método setDouble do PreparedStatement 
para preencher os valores que são do tipo double, passando a respectiva posição. 


5) Para testar nosso DÃO, desenvolva a classe TestaInsere no pacote 


br.com.etec. jdbc.teste com o método main. Gere o main pelo Eclipse, digite main e 
CTRL + espaço. 


6) O programa de testes deve, dentro do main, criar um novo objeto Produto com dados de 
teste e chamar a nova classe ProdutoDAO para adicioná-lo ao banco de dados. Lembre- 
se do atalho para imprimir no console, o System.out.println (syso + ctrl+ espaço). 


pablic class Testalnsere (Í 
pablic static void main (String[] args) f 

Produto produto = new Produto (); 
produto. setNome ("teclado"): 
produto. setDescrição ("Teclado..."); 
produto. setPreco (35.00); 
ProdutoDÃO dao = new ProdutoDÃO () ; 
dao. insere (produto); 
System. out.println ("Produto adicionado com sucesso!”); 


1) Execute seu programa. 

8) Verifique se o produto foi adicionado. Abra o MySQL e digite: 
use Jdbc; 
select * from proquio; 


9) Faça agora na classe ProdutoDÃO o método remove. Utilize a seguinte instrução SQL: 


DELETE [FROM] tabela 


[WHERE condição]; se omitir todas as linhas serão excluídas 


10)Faça agora na classe ProdutoDAO o método altera. Utilize a seguinte instrução SQL: 
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UPDATE Nometabela 
SET coluna= valor [, colunal=valor, ...] 


[WHERE condição]; se omitir todas as linhas serão atualizadas 


19.7. EXERCÍCIOS: Listando dados 





À instrução SQL que seleciona todos os registros no banco de dados: 
SELECT * FROM Nometabela; 


Como essa Instrução retorna os registros da tabela, precisamos utilizar a interface 
JDBC para navegação nos resultados, e para isso usaremos o ResultSet, que oferece 
métodos para recuperar resultados de comandos SQL executados sobre o banco de dados. 
Perceba que populamos o objeto com os dados conforme dados cadastrados nas tabelas e 
adicionamos em uma lista de produtos. 


1) Faça agora na classe ProdutoDÃO o método getLista() a seguir: 


public List<Produto> getListal) É 
try 4 
List<Produto> produtos = new ArrayList<Produto->()s 
PreparedStatement stmt = this.connection 
- prepareStatement ("select * from produto"); 


Result5Set rs = stmt.executeQuery (|): 


while (rs.next()) | 
Produto produto = new Produto (): 
(! popula o objeto produto 
produto. setId(rs.getInt (1)): 
produto. setNome (rs. get5String (2)): 
produto. setDescrição (rs.get5String(3)): 
produto.setPreco (rs. getDouble (4)); 
produtos.add (produto): 

k 

rs.close(): 

stmt.close(); 

retaorn produtos; 

: catch (5SQLException e) | 
throw new RuntimeException(e): 
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